• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 16:20
CEST 22:20
KST 05:20
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
Team Liquid Map Contest #22 - The Finalists14[ASL21] Ro16 Preview Pt1: Fresh Flow9[ASL21] Ro24 Preview Pt2: News Flash10[ASL21] Ro24 Preview Pt1: New Chaos0Team Liquid Map Contest #22 - Presented by Monster Energy21
Community News
2026 GSL Season 1 Qualifiers11Maestros of the Game 2 announced32026 GSL Tour plans announced13Weekly Cups (April 6-12): herO doubles, "Villains" prevail1MaNa leaves Team Liquid22
StarCraft 2
General
Blizzard Classic Cup @ BlizzCon 2026 - $100k prize pool 2026 GSL Tour plans announced MaNa leaves Team Liquid Team Liquid Map Contest #22 - The Finalists Weekly Cups (April 6-12): herO doubles, "Villains" prevail
Tourneys
Sparkling Tuna Cup - Weekly Open Tournament GSL CK: More events planned pending crowdfunding 2026 GSL Season 1 Qualifiers Master Swan Open (Global Bronze-Master 2) SEL Doubles (SC Evo Bimonthly)
Strategy
Custom Maps
[D]RTS in all its shapes and glory <3 [A] Nemrods 1/4 players [M] (2) Frigid Storage
External Content
Mutation # 522 Flip My Base The PondCast: SC2 News & Results Mutation # 521 Memorable Boss Mutation # 520 Moving Fees
Brood War
General
Data needed RepMastered™: replay sharing and analyzer site Gypsy to Korea ASL21 General Discussion BGH Auto Balance -> http://bghmmr.eu/
Tourneys
Escore Tournament StarCraft Season 2 [Megathread] Daily Proleagues [ASL21] Ro16 Group A [ASL21] Ro16 Group B
Strategy
Simple Questions, Simple Answers What's the deal with APM & what's its true value Any training maps people recommend? Fighting Spirit mining rates
Other Games
General Games
Nintendo Switch Thread General RTS Discussion Thread Battle Aces/David Kim RTS Megathread Stormgate/Frost Giant Megathread Starcraft Tabletop Miniature Game
Dota 2
The Story of Wings Gaming
League of Legends
G2 just beat GenG in First stand
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Deck construction bug Heroes of StarCraft mini-set
TL Mafia
Vanilla Mini Mafia Mafia Game Mode Feedback/Ideas TL Mafia Community Thread Five o'clock TL Mafia
Community
General
US Politics Mega-thread Things Aren’t Peaceful in Palestine Russo-Ukrainian War Thread YouTube Thread Canadian Politics Mega-thread
Fan Clubs
The IdrA Fan Club
Media & Entertainment
[Manga] One Piece Anime Discussion Thread [Req][Books] Good Fantasy/SciFi books Movie Discussion!
Sports
2024 - 2026 Football Thread McBoner: A hockey love story Formula 1 Discussion Cricket [SPORT]
World Cup 2022
Tech Support
[G] How to Block Livestream Ads
TL Community
The Automated Ban List
Blogs
Reappraising The Situation T…
TrAiDoS
lurker extra damage testi…
StaticNine
Broowar part 2
qwaykee
Funny Nicknames
LUCKY_NOOB
Iranian anarchists: organize…
XenOsky
ASL S21 English Commentary…
namkraft
Customize Sidebar...

Website Feedback

Closed Threads



Active: 1377 users

The Big Programming Thread - Page 841

Forum Index > General Forum
Post a Reply
Prev 1 839 840 841 842 843 1032 Next
Thread Rules
1. This is not a "do my homework for me" thread. If you have specific questions, ask, but don't post an assignment or homework problem and expect an exact solution.
2. No recruiting for your cockamamie projects (you won't replace facebook with 3 dudes you found on the internet and $20)
3. If you can't articulate why a language is bad, don't start slinging shit about it. Just remember that nothing is worse than making CSS IE6 compatible.
4. Use [code] tags to format code blocks.
Deleted User 101379
Profile Blog Joined August 2010
4849 Posts
February 10 2017 08:38 GMT
#16801
On February 10 2017 12:18 WarSame wrote:
What is an elegant way to set a bunch of div colours in SASS?

I would ideally like to do something like
$brown: #955436
$lightblue: #AAE0FA
$pink: #D93A96
$orange: #F7941D
$red: #ED1B24
$yellow: #FEF224
$green: #1FB25A
$darkblue: #0072BB

.block-(colorexample)
background-color:$colorexample


where I could have divs with classes like
block-brown
and have it automatically sub in the colour. Should I just not bother and make a block-colour for every single colour I have?


Please don't.

Name your CSS classes after what they represent, not after what they look like. Otherwise you'll either have to search and replace all the instances when your Boss tells you that all brown buttons should now be green, which negates all the advantages of CSS, or you have a class "brown" that is now green.
Artesimo
Profile Joined February 2015
Germany571 Posts
Last Edited: 2017-02-10 08:42:40
February 10 2017 08:38 GMT
#16802
Last questions:

About JOIN, if I got a ManyToMany Relationshipt between say, Students and lecturers:


ListL result em.createQuery("SELECT s, l FROM Studens s join s.lectures")
for(Iterator i = resultL.iterator(); i.hasNext();)
{
Object [] element = (Object[]) i.hasNext()//each Object[] containing a Student at [0] and a lecture at[1]
//using get-Methods to get Student/Lecture Name and printing it out


My Output would be equivalent to the joinedtable, where for every Student, all lectures get Listet:

_Student_ _Lecture_
Hans Lecture 1
Hans Lecture 2
Hans Lecture 3
Max Lecture 2
Max Lecture 3
Anna Lecture 3
. .
. .
. .
. .
Correct?

I could also acess the name of the Students directly, via using "SELECT s.name, l.name" instead.

An implicit join would also work like:

Select s, l,
FROM Student s, lesson l


Or to only get Name+all courses of one Students:

Select s, l,
FROM Student s, lesson l
WHERE s.name = "Hans"



Last question regarding general understanding:
All Querys in the end will be translated into SQL and send to the Database, this happens either after commiting an transaktion or calling flush() (which can be dangerous since it leaves the transaktionscope open, If the transaction fails afterwards, changes made before flush() are still in the database unless handled properly). However, how do you acess objekts then, that arent in the persitence context, but in the DB.

EntityManager em = emf.createEntityManager();//Session created
EntityTransaction tx = null;
try{
tx = em.getTransaction(); //transaction context created
tx.begin() //start transaciton();
// Customer001 previously not in persistence context/Cache
customer myCustomer = em.find(Customer.class, 001);//Now in persistence context
/*
Interaction with the object I pulled from the database - How can this work,
if the select-statement only get send after the commit?
Or get everything that you need for the tx get pulled from the DB before/em.find()
circumvents the commit? What about Entities pulled with JPQL-Querys?
*/
String name = myCustomer.getName()//
myCustomer.setName = "MC";

tx.commit();//End of transaction, transactions get send to DB
}catch (RuntimeException e){
if(tx != null) && tx.isActive()) tx.rollback();//Rollback transaction in case something went wrong, and tx got created
throw e;}
finally{em.close();} //closing the session
Manit0u
Profile Blog Joined August 2004
Poland17727 Posts
February 10 2017 09:49 GMT
#16803
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.
Time is precious. Waste it wisely.
Artesimo
Profile Joined February 2015
Germany571 Posts
February 10 2017 09:59 GMT
#16804
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


So it doesn't work, or it is just really clunky? In case of it working, is my assumption correct, that fetching always happens immediately and only inserts/update/delete statements get hold back until .commit() is called?
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 10:20 GMT
#16805
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


Not true if you care about isolation and atomicity. It can lead to serious issues specially in financial applications.
Manit0u
Profile Blog Joined August 2004
Poland17727 Posts
February 10 2017 10:57 GMT
#16806
On February 10 2017 19:20 Hanh wrote:
Show nested quote +
On February 10 2017 18:49 Manit0u wrote:
Just fetch the objects you need before starting the transaction. You should really only use transactions for insert/update statements, not fetching.


Not true if you care about isolation and atomicity. It can lead to serious issues specially in financial applications.


It really depends on what you need and what you're working with. Also, different SQL servers handle transactions differently (MS SQL for example will not allow for any other queries - even reads - until the transaction is commited and closed). Sure, if data integrity is critical, you want to wrap everything in transactions (and possibly add other mechanisms of ensuring that) but for the majority of use cases you won't need that level of paranoia.
Time is precious. Waste it wisely.
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 11:09 GMT
#16807
This isn't paranoia. It is about a program behaving correctly or not. Saying that I don't need to do a transaction because I am only reading is the same as saying that I don't need to use a lock because I'm reading data (except that you won't crash because the database is always acquiring integrity locks). In some cases it is fine because there is an implicit transaction or auto commit in place. Yet if someone is learning about transactions, he should do the right thing.
Artesimo
Profile Joined February 2015
Germany571 Posts
Last Edited: 2017-02-10 11:34:36
February 10 2017 11:31 GMT
#16808
But I still struggle with the fact that the DB gets the data on commit, while I use fetches inside the transaction without having commited first. Does fetch always immediately get passed on to the DB and only write/delete/inserts/everything that manipulates data get send only on commit?
(In other words, persistence context stuff like adding/changing/removing data in/from it gets applied immediately, the Database only gets changed on commit. Fetching inside a transaction doesnt change anything on the DB but loads aditional entities in the persistence context? On commit, the persistence context will be synchronized with the DB)
Hanh
Profile Joined June 2016
146 Posts
February 10 2017 12:09 GMT
#16809
I don't know what the JPA (?) layer does but speaking from the database point of view, your transaction delimits a unit of execution that is Atomic and Isolated (A and I of ACID). Atomicity means that: Everything succeeds or everything fails. For instance, if you do 2 inserts and the 2nd one fails because of a constraint violation both inserts roll back. It doesn't mean that these inserts are sent at the end of the transaction. If you fetch something, then update it, and fetch again, your second fetch will return the updated value - even if the transaction isn't committed.
Isolation is more complicated but ideally, while your transaction is underway you don't see the actions of other transactions that are run concurrently. There are subtleties because isolation impacts performance and database implementations typically offer several options of isolation level.
WarSame
Profile Blog Joined February 2010
Canada1950 Posts
February 11 2017 03:36 GMT
#16810
On February 10 2017 17:38 Morfildur wrote:
Show nested quote +
On February 10 2017 12:18 WarSame wrote:
What is an elegant way to set a bunch of div colours in SASS?

I would ideally like to do something like
$brown: #955436
$lightblue: #AAE0FA
$pink: #D93A96
$orange: #F7941D
$red: #ED1B24
$yellow: #FEF224
$green: #1FB25A
$darkblue: #0072BB

.block-(colorexample)
background-color:$colorexample


where I could have divs with classes like
block-brown
and have it automatically sub in the colour. Should I just not bother and make a block-colour for every single colour I have?


Please don't.

Name your CSS classes after what they represent, not after what they look like. Otherwise you'll either have to search and replace all the instances when your Boss tells you that all brown buttons should now be green, which negates all the advantages of CSS, or you have a class "brown" that is now green.

In this case they are going to be blocks to build a monopoly board, though, so they need to be named by colour.
Can it be I stayed away too long? Did you miss these rhymes while I was gone?
berated-
Profile Blog Joined February 2007
United States1134 Posts
Last Edited: 2017-02-11 12:48:27
February 11 2017 12:46 GMT
#16811
On February 10 2017 20:31 Artesimo wrote:
But I still struggle with the fact that the DB gets the data on commit, while I use fetches inside the transaction without having commited first. Does fetch always immediately get passed on to the DB and only write/delete/inserts/everything that manipulates data get send only on commit?
(In other words, persistence context stuff like adding/changing/removing data in/from it gets applied immediately, the Database only gets changed on commit. Fetching inside a transaction doesnt change anything on the DB but loads aditional entities in the persistence context? On commit, the persistence context will be synchronized with the DB)


The DB definitely does not only get the data on commit. JPA is just built on top of JDBC, which gets a connection and starts a transaction if you are using your transaction manager. As others have tried to explain, and probably better than I will, you are actively participating in a database transaction at that time.

If you are trying to look at the database while your code has a transaction going on, you won't be able to see it -- that's the part of the isolation levels etc. It might feel like everything happens on commit, but, that's just when everything is actually committed, not when it is transferred.

If you are in the scope of a transaction, you can read the changes that you have made but others can't (most of the time).

Here is some reading on JDBC Transactions

Underneath the hood, when you start the transaction, it takes the connection that you have and turns off auto commit. Then every time you run something with JPA, it takes the jdbc connection and prepares a statement and then executes it -- all of that is done until you call commit.


Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 19:57 GMT
#16812
So, C question.

I want to create a program that takes in input of the total number of variables that will have to be put into an array

then create an array that has size based on that input

but im reading that arrays can't be created with a variable as the size
wtf is that about, that seems really annoying
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
Last Edited: 2017-02-11 20:24:02
February 11 2017 20:20 GMT
#16813
On February 12 2017 04:57 travis wrote:
So, C question.

I want to create a program that takes in input of the total number of variables that will have to be put into an array

then create an array that has size based on that input

but im reading that arrays can't be created with a variable as the size
wtf is that about, that seems really annoying


Are you compiling C89 standard or C99 standard? The rules are different for each. The short answer is that the compiler wants to know exactly how much memory will be needed on the stack for your array.

The simple solution is to allocate on the heap using malloc, but that might not be what your class wants you to do.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 20:29 GMT
#16814
I think they want me to just initialize each array to size 50, because they told us in specifications that they won't need to hold more than 50 elements

but I don't like the huge lack in knowledge that comes with that hehe

I am finding I am not a big fan of C.... too much stuff that takes too long to do
Nesserev
Profile Blog Joined January 2011
Belgium2760 Posts
Last Edited: 2017-02-11 21:41:13
February 11 2017 21:17 GMT
#16815
--- Nuked ---
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
Last Edited: 2017-02-11 21:22:04
February 11 2017 21:18 GMT
#16816
On February 12 2017 05:29 travis wrote:
I think they want me to just initialize each array to size 50, because they told us in specifications that they won't need to hold more than 50 elements

but I don't like the huge lack in knowledge that comes with that hehe

I am finding I am not a big fan of C.... too much stuff that takes too long to do


If you know the max size will be 50 its as simple as:
const int MAX_SIZE = 50;


When you compile your code the compiler knows that the arrays size is 50. It knows exactly how much stack space to allocate and it is happy.

extern int MAX_SIZE;


Contrast with the above where you're getting the max size from somewhere else. The compiler doesn't know what the value will be and it won't let you compile.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Biolunar
Profile Joined February 2012
Germany224 Posts
February 11 2017 21:41 GMT
#16817
If you do this:
const int MAX_SIZE = 50;
T arr[MAX_SIZE];

then arr is a VLA. Don't use VLAs.
What is best? To crush the Zerg, see them driven before you, and hear the lamentations of the Protoss.
Deleted User 3420
Profile Blog Joined May 2003
24492 Posts
February 11 2017 21:50 GMT
#16818
what about #define ARRAY_LENGTH 50 ?
Nesserev
Profile Blog Joined January 2011
Belgium2760 Posts
Last Edited: 2017-02-11 22:14:55
February 11 2017 22:03 GMT
#16819
--- Nuked ---
Blitzkrieg0
Profile Blog Joined August 2010
United States13132 Posts
February 11 2017 22:24 GMT
#16820
I was under the impression that a constant didn't change value, but when I wrote C89 was the worst months of my life so I'll just refrain from answering anymore about it since apparently I don't remember anything.
I'll always be your shadow and veil your eyes from states of ain soph aur.
Prev 1 839 840 841 842 843 1032 Next
Please log in or register to reply.
Live Events Refresh
AI Arena Tournament
19:00
KOTH
Laughngamez YouTube
BSL
19:00
RO32 Group D
StRyKeR vs rasowy
Artosis vs Aether
JDConan vs OyAji
Hawk vs izu
ZZZero.O305
LiquipediaDiscussion
Ladder Legends
15:00
Valedictorian Cup #1 Qualifier
SteadfastSC215
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
elazer 390
SteadfastSC 215
JuggernautJason82
BRAT_OK 77
LaughNgamez 2
StarCraft: Brood War
Calm 3176
Mini 562
ZZZero.O 289
actioN 118
Dewaltoss 84
Movie 31
NaDa 7
League of Legends
JimRising 92
Counter-Strike
fl0m8676
olofmeister3899
byalli482
Super Smash Bros
Mew2King83
Heroes of the Storm
Khaldor477
Other Games
summit1g6670
Grubby3867
FrodaN1016
B2W.Neo803
KnowMe226
Pyrionflax153
ArmadaUGS81
RotterdaM80
mouzStarbuck26
Organizations
Other Games
gamesdonequick805
StarCraft 2
ComeBackTV 792
Other Games
BasetradeTV524
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 15 non-featured ]
StarCraft 2
• Reevou 4
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• FirePhoenix3
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
League of Legends
• Doublelift2069
Other Games
• imaqtpie1224
• Shiphtur172
Upcoming Events
Replay Cast
3h 40m
Replay Cast
12h 40m
Wardi Open
13h 40m
Afreeca Starleague
13h 40m
Bisu vs Ample
Jaedong vs Flash
Monday Night Weeklies
19h 40m
RSL Revival
1d 5h
GSL
1d 11h
Afreeca Starleague
1d 13h
Barracks vs Leta
Royal vs Light
WardiTV Map Contest Tou…
1d 14h
RSL Revival
2 days
[ Show More ]
Replay Cast
3 days
The PondCast
3 days
KCM Race Survival
3 days
WardiTV Map Contest Tou…
3 days
CranKy Ducklings
4 days
Escore
4 days
RSL Revival
4 days
WardiTV Map Contest Tou…
5 days
Universe Titan Cup
5 days
Rogue vs Percival
Ladder Legends
5 days
uThermal 2v2 Circuit
5 days
BSL
5 days
Sparkling Tuna Cup
6 days
WardiTV Map Contest Tou…
6 days
Ladder Legends
6 days
BSL
6 days
Liquipedia Results

Completed

Escore Tournament S2: W3
RSL Revival: Season 4
NationLESS Cup

Ongoing

BSL Season 22
ASL Season 21
CSL 2026 SPRING (S20)
IPSL Spring 2026
KCM Race Survival 2026 Season 2
StarCraft2 Community Team League 2026 Spring
WardiTV TLMC #16
Nations Cup 2026
IEM Rio 2026
PGL Bucharest 2026
Stake Ranked Episode 1
BLAST Open Spring 2026
ESL Pro League S23 Finals
ESL Pro League S23 Stage 1&2
PGL Cluj-Napoca 2026
IEM Kraków 2026

Upcoming

Escore Tournament S2: W4
Acropolis #4
BSL 22 Non-Korean Championship
CSLAN 4
Kung Fu Cup 2026 Grand Finals
HSC XXIX
uThermal 2v2 2026 Main Event
2026 GSL S2
RSL Revival: Season 5
2026 GSL S1
XSE Pro League 2026
IEM Cologne Major 2026
Stake Ranked Episode 2
CS Asia Championships 2026
IEM Atlanta 2026
Asian Champions League 2026
PGL Astana 2026
BLAST Rivals Spring 2026
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2026 TLnet. All Rights Reserved.